<template>
  <div class="reportFormPage">
    <div class="report-dom">
      <el-row>
        <el-col :span="5" :offset="19">
          <div class="pageNumBox">
            <span>第</span>
            <span class="placeholder-min text-center">&nbsp;{{ form.page }}&nbsp;</span>
            <span>页，共</span>
            <span class="placeholder-min text-center">&nbsp;{{ form.totalPage }}&nbsp;</span>
            <span>页</span>
          </div>
        </el-col>
      </el-row>
      <div class="topTwoBox">
        <div class="centerName">钢材弯曲性能、反向弯曲性能试验检测记录表</div>
        <div class="codeText">JGLQ15007<br/>JGLQ15008</div>
      </div>
      <div class="threeTopBox">
        <div class="left-border">
          <div class="box-title">检测单位名称：</div>
          <div class>{{ form.jiancdwmc }}</div>
        </div>
        <div class="right-border">
          <span>记录编号：</span>
          <span v-if="isPdf" class="placeholder">{{ form.jilbh }}</span>
          <el-input class="code-input" v-else type="text" v-model="form.jilbh" @focus="handleFocus('jilbh')"/>
        </div>
      </div>
      <div class="table-border">
        <!------------------------------表头-------------------------->
        <table height="220px" class="top-table">
          <tbody>
          <tr>
            <td height="30" align="center" width="15%">
              <span style="width: 90px; display: inline-block">工程名称</span>
            </td>
            <td width="35%" class="text-center">
              <span>{{ form.gongcmc }}</span>
            </td>
            <td align="center" width="15%">
              <span style="width: 90px; display: inline-block">工程部位/用途</span>
            </td>
            <td width="35%" class="text-center">
              <span>{{ form.gongcbwyt }}</span>
            </td>
          </tr>
          <tr>
            <td height="50" align="center">样品信息</td>
            <td class="specimen-border" colspan="3">
              <span>样品名称：</span>
              <span :class="{ placeholder: !form.yangpmc }">{{ form.yangpmc }}</span>
              <span>；样品编号：</span>
              <span :class="{ 'placeholder-long': !form.yangpbh }">{{ form.yangpbh }}</span>
              <span>；样品数量：</span>
              <span :class="{ placeholder: !form.yangpsl }">{{ form.yangpsl }}</span>
              <span>；样品状态：</span>
              <span :class="{ placeholder: !form.yangpzt }">{{ form.yangpzt }}</span>
              <span>；来样时间：</span>
              <span :class="{ placeholder: !form.yangpsj }">{{ form.yangpsj }}</span>
            </td>
          </tr>

          <tr>
            <td height="25" align="center" width="15%">
              <span style="width: 90px; display: inline-block">试验检测日期</span>
            </td>
            <!-- <td width="35%" class="text-center">{{ form.shiyjcrq }}</td> -->
            <td width="35%" class="text-center">
              <el-input v-model="form.shiyjcrq"/>
            </td>
            <td align="center" width="15%">
              <span style="width: 90px; display: inline-block">试验条件</span>
            </td>
            <td v-if="isPdf" width="35%">
              温度：
              <span style="display: inline-block; width: 10%">{{ form.shiytjwd }}</span>
              ℃；湿度：
              <span style="display: inline-block; width: 10%">{{ form.shiytjsd }}</span>%RH
            </td>
            <td v-else width="35%">
              温度：
              <el-input :type="isPdf ? 'string' : 'number'" v-model="form.shiytjwd" style="width: 15%"/>
              ℃；湿度：
              <el-input :type="isPdf ? 'string' : 'number'" v-model="form.shiytjsd" style="width: 15%"/>
              %RH
            </td>
          </tr>

          <tr>
            <td height="50" align="center" width="15%">
              <span style="width: 90px; display: inline-block">检测依据</span>
            </td>
            <td width="35%">
              <span v-if="isPdf">{{ form.jiancyj }}</span>
              <el-input v-else type="textarea" v-model="form.jiancyj" :rows="2" class="mark"
                        @dblclick.native="showBsJiancyjView" readonly/>
            </td>
            <td align="center" width="15%">
              <span style="width: 90px; display: inline-block">判定依据</span>
            </td>
            <td width="35%">
              <span v-if="isPdf">{{ form.pandyj }}</span>
              <el-input v-else type="textarea" v-model="form.pandyj" :rows="2" @dblclick.native="showBsJudgeBaseView"
                        @focus="handleFocus('pandyj')" class="mark"/>
            </td>
          </tr>
          <tr class="bottom-border">
            <td height="50" align="center">
              <div>主要仪器设备</div>
              <div>名称及编号</div>
            </td>
            <td colspan="3">
              <span v-if="isPdf">{{ form.zhuyyqsbmcjbh }}</span>
              <el-input v-else type="textarea" :rows="2" v-model="form.zhuyyqsbmcjbh" class="height100 width100 mark"
                        @dblclick.native="showBsInstrumentView" readonly></el-input>
            </td>
          </tr>
          </tbody>
        </table>
        <!------------------------------表中-------------------------->
        <table height="616px" class="middle-table">
          <tbody>
          <tr height="25">
            <td>规格牌号</td>
            <td colspan="2">
              <el-input type="text" v-model="form.guigxh" @keydown.native="handleKeyDown($event, 0, 0)"
                        :ref="'0_0'"/>
            </td>
            <td>代表数量</td>
            <td colspan="2">
              <el-input type="text" v-model="form.daibsl" @keydown.native="handleKeyDown($event, 0, 1)"
                        :ref="'0_1'"/>
            </td>
            <td>取样地点</td>
            <td colspan="2">
              <el-input type="text" v-model="form.quydd" @keydown.native="handleKeyDown($event, 0, 2)"
                        :ref="'0_2'"/>
            </td>
          </tr>
          <tr height="25">
            <td>批号</td>
            <td colspan="4">
              <el-input type="text" v-model="form.pih" @keydown.native="handleKeyDown($event, 1, 0)"
                        :ref="'1_0'"/>
            </td>
            <td>生产厂家</td>
            <td colspan="3">
              <el-input type="text" v-model="form.cd" @keydown.native="handleKeyDown($event, 1, 1)"
                        :ref="'1_1'"/>
            </td>
          </tr>
          <tr height="25">
            <td rowspan="2">公称直径(mm)</td>
            <td rowspan="2">公称截面积(mm²)</td>
            <td colspan="3">弯曲性能</td>
            <td colspan="4">反向弯曲性能</td>
          </tr>
          <tr height="40">
            <td>压头直径(mm)</td>
            <td>弯曲角度(°)</td>
            <td>试验结果</td>
            <td>压头直径(mm)</td>
            <td>弯曲角度(°)</td>
            <td>反向弯曲角度(°)</td>
            <td>试验结果</td>
          </tr>
          <tr height="25">
            <td style="width: calc(100% / 9 * 1)" rowspan="2">
              <el-input type="number" v-model="form.gongczj1"
                        @change="countgongczj(1, 1, 2)" @keydown.native="handleKeyDown($event, 2, 0)" :ref="'2_0'"/>
            </td>
            <td style="width: calc(100% / 9 * 1)" rowspan="2">
              <el-input type="number" v-model="form.gongcjmj1"
                        disabled/>
            </td>
            <td style="width: calc(100% / 9 * 1)">
              <el-input type="number" v-model="form.wanqytzj1" disabled/>
            </td>
            <td style="width: calc(100% / 9 * 1)">
              <el-input type="text" v-model="form.wanqjd1"
                        @change="handleYtzj(1, 1)" @keydown.native="handleKeyDown($event, 2, 1)" :ref="'2_1'"/>
            </td>
            <td style="width: calc(100% / 9 * 1)">
              <el-input type="text" v-model="form.wanqsyjg1"
                        @change="handleBusWqxn(0)" @keydown.native="handleKeyDown($event, 2, 2)" :ref="'2_2'"/>
            </td>
            <td style="width: calc(100% / 9 * 1)" rowspan="2">
              <el-input type="number" v-model="form.fanxytzj1"
                        disabled/>
            </td>
            <td style="width: calc(100% / 9 * 1)" rowspan="2">
              <el-input type="text" v-model="form.fanxjd1"
                        @change="handleYtzj2(1)" @keydown.native="handleKeyDown($event, 2, 3)" :ref="'2_3'"/>
            </td>
            <td style="width: calc(100% / 9 * 1)" rowspan="2">
              <el-input type="text" v-model="form.fanxfxjd1"
                        @keydown.native="handleKeyDown($event, 2, 4)" :ref="'2_4'"/>
            </td>
            <td style="width: calc(100% / 9 * 1)" rowspan="2">
              <el-input type="text" v-model="form.fanxsyjd1"
                        @change="handleBusFxwq(0, form.fanxsyjd1)" @keydown.native="handleKeyDown($event, 2, 5)"
                        :ref="'2_5'"/>
            </td>
          </tr>
          <tr height="25">
            <td>
              <el-input type="number" v-model="form.wanqytzj2" disabled/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqjd2" @change="handleYtzj(1, 2)"
                        @keydown.native="handleKeyDown($event, 3, 1)" :ref="'3_1'"/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqsyjg2" @change="handleBusWqxn(1)"
                        @keydown.native="handleKeyDown($event, 3, 2)" :ref="'3_2'"/>
            </td>
          </tr>
          <tr height="25">
            <td rowspan="2">
              <el-input type="number" v-model="form.gongczj3" @change="countgongczj(3, 3, 4)"
                        @keydown.native="handleKeyDown($event, 4, 0)" :ref="'4_0'"/>
            </td>
            <td rowspan="2">
              <el-input type="number" v-model="form.gongcjmj3" disabled/>
            </td>
            <td>
              <el-input type="number" v-model="form.wanqytzj3" disabled/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqjd3" @change="handleYtzj(3, 3)"
                        @keydown.native="handleKeyDown($event, 4, 1)" :ref="'4_1'"/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqsyjg3" @change="handleBusWqxn(2)"
                        @keydown.native="handleKeyDown($event, 4, 2)" :ref="'4_2'"/>
            </td>
            <td rowspan="2">
              <el-input type="number" v-model="form.fanxytzj3" disabled/>
            </td>
            <td rowspan="2">
              <el-input type="text" v-model="form.fanxjd3" @change="handleYtzj2(3)"
                        @keydown.native="handleKeyDown($event, 4, 3)" :ref="'4_3'"/>
            </td>
            <td rowspan="2">
              <el-input type="text" v-model="form.fanxfxjd3"
                        @keydown.native="handleKeyDown($event, 4, 4)" :ref="'4_4'"/>
            </td>
            <td rowspan="2">
              <el-input type="text" v-model="form.fanxsyjd3" @change="handleBusFxwq(2, form.fanxsyjd3)"
                        @keydown.native="handleKeyDown($event, 4, 5)" :ref="'4_5'"/>
            </td>
          </tr>
          <tr height="25">
            <td>
              <el-input type="number" v-model="form.wanqytzj4" disabled/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqjd4" @change="handleYtzj(3, 4)"
                        @keydown.native="handleKeyDown($event, 5, 1)" :ref="'5_1'"/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqsyjg4" @change="handleBusWqxn(3)"
                        @keydown.native="handleKeyDown($event, 5, 2)" :ref="'5_2'"/>
            </td>
          </tr>
          <tr height="25">
            <td rowspan="2">
              <el-input type="number" v-model="form.gongczj5" @change="countgongczj(5, 5, 6)"
                        @keydown.native="handleKeyDown($event, 6, 0)" :ref="'6_0'"/>
            </td>
            <td rowspan="2">
              <el-input type="number" v-model="form.gongcjmj5" disabled/>
            </td>
            <td>
              <el-input type="number" v-model="form.wanqytzj5" disabled/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqjd5" @change="handleYtzj(5, 5)"
                        @keydown.native="handleKeyDown($event, 6, 1)" :ref="'6_1'"/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqsyjg5" @change="handleBusWqxn(4)"
                        @keydown.native="handleKeyDown($event, 6, 2)" :ref="'6_2'"/>
            </td>
            <td rowspan="2">
              <el-input type="number" v-model="form.fanxytzj5" disabled/>
            </td>
            <td rowspan="2">
              <el-input type="text" v-model="form.fanxjd5" @change="handleYtzj2(5)"
                        @keydown.native="handleKeyDown($event, 6, 3)" :ref="'6_3'"/>
            </td>
            <td rowspan="2">
              <el-input type="text" v-model="form.fanxfxjd5"
                        @keydown.native="handleKeyDown($event, 6, 4)" :ref="'6_4'"/>
            </td>
            <td rowspan="2">
              <el-input type="text" v-model="form.fanxsyjd5" @change="handleBusFxwq(4, form.fanxsyjd5)"
                        @keydown.native="handleKeyDown($event, 6, 5)" :ref="'6_5'"/>
            </td>
          </tr>
          <tr height="25">
            <td>
              <el-input type="number" v-model="form.wanqytzj6" disabled/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqjd6" @change="handleYtzj(5, 6)"
                        @keydown.native="handleKeyDown($event, 7, 1)" :ref="'7_1'"/>
            </td>
            <td>
              <el-input type="text" v-model="form.wanqsyjg6" @change="handleBusWqxn(5)"
                        @keydown.native="handleKeyDown($event, 7, 2)" :ref="'7_2'"/>
            </td>
          </tr>
          </tbody>
        </table>
        <!------------------------------附加声明-------------------------->
        <table height="60px" class="bottom-table">
          <tr>
            <td>
              <span v-if="isPdf" class="textarea-span">{{ form.fujsm }}</span>
              <el-input v-else type="textarea" :rows="2" v-model="form.fujsm" @focus="handleFocus('fujsm')"/>
            </td>
          </tr>
        </table>
      </div>
      <!------------------------------表底-------------------------->
      <table height="22px" class="transparent">
        <tbody>
        <tr>
          <td width="10%" align="right">检测：</td>
          <td width="15%" align="left"></td>
          <td width="10%" align="right">记录：</td>
          <td width="15%" align="left"></td>
          <td width="10%" align="right">复核：</td>
          <td align="left" width="15%"></td>
          <td width="10%">日期：</td>
          <td align="left" width="15%">
            <div style="display: inline-block; margin-left: 20px">年</div>
            <div style="display: inline-block; margin-left: 20px">月</div>
            <div style="display: inline-block ;margin-left: 20px">日</div>
          </td>
        </tr>
        </tbody>
      </table>
    </div>
    <bs-instrument-view ref="bsInstrumentViewRef" @select="selectInstrument"></bs-instrument-view>
    <bs-jiancyj-view ref="bsJiancyjViewRef" @select="selectJiancyj" :syType="syType"></bs-jiancyj-view>
    <bs-judge-base-view ref="bsJudgeBaseViewRef" @select="selectJudge" :syType="syType"></bs-judge-base-view>
  </div>
</template>

<script>
import {
  listGcwqxnfxwqxnjlbBsInfo,
  getGcwqxnfxwqxnjlbBsInfo,
  delGcwqxnfxwqxnjlbBsInfo,
  addGcwqxnfxwqxnjlbBsInfo,
  updateGcwqxnfxwqxnjlbBsInfo
} from "@/api/report_gc/gcwqxnfxwqxnjlbBsInfo";
import BsInstrumentView from "@/views/dept/bsInstrument/BsInstrumentView.vue";
import BsJiancyjView from "@/views/sycs/bsJiancyj/BsJiancyjView.vue";
import decimal from "@/utils/big-decimal";
import BsJudgeBaseView from "@/views/sycs/bsJudgeBase/BsJudgeBaseView";
import {handleFocus, handleKeyDown} from "@/views/reportForms/utils";
import Bus from "@/utils/bus";

export default {
  name: "gcwqxnfxwqxnjlb",
  components: {
    BsInstrumentView,
    BsJiancyjView,
    BsJudgeBaseView
  },
  props: {
    excelId: {
      type: [String, Number],
      default: () => ""
    },
    syType: {
      type: [String, Number],
      default: () => ""
    },
    page: {
      type: Number,
      default: () => 0
    },
    isPdf: {
      type: Boolean,
      default: () => false
    }
  },
  data() {
    return {
      params: {},
      query: {},
      // 表单参数
      form: {},
      // 表单校验
      rules: {
        excelId: [{required: true, message: "主键不能为空", trigger: "blur"}]
      }
    };
  },
  created() {
    this.getInfo();
  },
  methods: {
    // 获取详情
    getInfo() {
      getGcwqxnfxwqxnjlbBsInfo(this.excelId || this.$defaultExcelId).then((response) => {
        this.form = response.data;
        if (!this.form.fujsm) {
          this.form.fujsm = "附加声明：";
        }
      });
    },

    // 显示检测依据列表
    showBsJiancyjView() {
      this.$refs.bsJiancyjViewRef.init(this.form.jiancyjIds);
    },
    // 检测依据选择
    selectJiancyj(info) {
      this.form.jiancyj = info.label;
      this.form.jiancyjIds = info.ids;
      Bus.$emit("setGcsyjcBgJiancyj", {jiancyj: this.form.jiancyj, jiancyjIds: this.form.jiancyjIds});
    },

    // 显示判定依据列表
    showBsJudgeBaseView() {
      this.$refs.bsJudgeBaseViewRef.init(this.form.pandyjIds);
    },
    // 判断依据选择
    selectJudge(info) {
      this.form.pandyjIds = info.ids;
      this.form.pandyj = info.label;
    },

    // 显示仪器列表
    showBsInstrumentView() {
      this.$refs.bsInstrumentViewRef.init(this.form.shebIds);
    },
    // 仪器选择
    selectInstrument(info) {
      this.form.zhuyyqsbmcjbh = info.label;
      this.form.shebIds = info.ids;
      Bus.$emit("setGcsyjcBgZhuyyqsbmcjbh", {zhuyyqsbmcjbh: this.form.zhuyyqsbmcjbh, shebIds: this.form.shebIds});
    },
    handleBusFxwq(num, val) {
      Bus.$emit("setGcFxwqXN", {[num]: val});
    },
    handleBusWqxn(num) {
      Bus.$emit("setGcWqxn", {[num]: this.form["wanqsyjg" + (num + 1)]});
    },
    handleFocus(event) {
      handleFocus(event, this.page, this.form[event]);
    },
    countgongczj(num, setNum1, setNum2) {
      let A = Number(this.form["gongczj" + num]);
      let F = (A / 2) * (A / 2) * 3.1415926;
      this.form["gongcjmj" + num] = A ? decimal.round(Number(F), 1) : undefined;
      // this.form["wanqytzj" + setNum1] = decimal.round(4 * A, 1);
      // this.form["wanqytzj" + setNum2] = decimal.round(4 * A, 1);
      // this.form["fanxytzj" + num] = decimal.round(5 * A, 1);
      this.handleYtzj(num, num)
      this.handleYtzj(num, num + 1)
      this.handleYtzj2(num)
    },
    handleYtzj(num, setNum1) {
      let A = Number(this.form["gongczj" + num]);
      if (A) {
        this.form["wanqytzj" + setNum1] = decimal.round(4 * A, 1);
      } else {
        this.form["wanqytzj" + setNum1] = undefined;
      }
    },
    handleYtzj2(num) {
      let A = Number(this.form["gongczj" + num]);
      if (A) {
        this.form["fanxytzj" + num] = decimal.round(5 * A, 1);
      } else {
        this.form["fanxytzj" + num] = undefined;
      }
    },
    submitForm() {
      return this.form;
    },
    handleKeyDown(event, rowIndex, colIndex) {
      const maxArr = [2, 1, 5, 2, 5, 2, 5, 2]; // 每一行最多有多少可聚焦输入框（从0开始）
      const ref = handleKeyDown(event, rowIndex, colIndex, maxArr);
      const arr = ref.split("_");
      if (arr[0] >= 2 && arr[0] <= 7 && !this.$refs[ref]) {
        this.handleKeyDown(event, arr[0], arr[1]);
        return;
      }
      if (this.$refs[ref]) {
        this.$refs[ref].focus();
      }
    }
  }
};
</script>

<style scoped></style>
